import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import 'font-awesome/css/font-awesome.css'

import {postRequest} from './utils/Api'
import {putRequest} from './utils/Api'
import {getRequest} from './utils/Api'
import {deleteRequest} from './utils/Api'
import {initMenu} from "@/utils/menu";


Vue.config.devtools = true;

Vue.config.productionTip = false
Vue.use(ElementUI,{size:'small'});

Vue.prototype.postRequest = postRequest
Vue.prototype.putRequest = putRequest
Vue.prototype.getRequest = getRequest
Vue.prototype.deleteRequest = deleteRequest

router.beforeEach((to, from, next) => {
    if (window.sessionStorage.getItem('token')) {
        initMenu(router, store)
        //判断用户信息是否存在
        if (!window.sessionStorage.getItem('user')){
            return getRequest('/admin/info').then(resp=>{
                if (resp){
                    //存入用户信息
                    window.sessionStorage.setItem('user',JSON.stringify(resp))
                    next();
                }
            })
        }
        next();
    } else {
        if(to.path=='/'){
            next();
        }else {
            next('/?redirect='+to.path);
        }
    }
})

new Vue({
    router,
    store,
    render: h => h(App)
}).$mount('#app')
